home *** CD-ROM | disk | FTP | other *** search
/ PC-Blue - MS DOS Public Domain Library / PC-Blue MS-DOS Public Domain Library - NYACC.iso / vol285 / listpci.bas (.txt) < prev    next >
Encoding:
GW-BASIC  |  1987-03-15  |  3.3 KB  |  118 lines

  1. 100  REM LISTPCI Program.
  2. 110  REM Prints the Parent/Child Index
  3. 120  REM Copyright (c) 1983 - 1987 by: Melvin O. Duke.
  4. 130  DEFINT A-Z
  5. 600  REM Titles
  6. 610  TITLE$ = "List the Parent/Child Index"
  7. 620  TITLE$ = TITLE$ + " ON DISPLAY"
  8. 700  REM Terminate if not called from the Menu
  9. 710  IF DD.MENU$ <> "" THEN 770
  10. 720  COLOR 7,0 : KEY ON : CLS : LOCATE 15,1
  11. 730  PRINT "Cannot run the"
  12. 740  PRINT TITLE$
  13. 750  PRINT "Program, unless selected from the MENU"
  14. 760  END
  15. 770  REM OK
  16. 1000  REM Produce the first screen
  17. 1010  KEY ON : CLS : KEY OFF
  18. 1020  REM Draw the outer double box
  19. 1030  R1 = 1 : C1 = 1 : R2 = 24 : C2 = 79 : GOSUB 1300
  20. 1040  REM Find the title location
  21. 1050  TITLE.POS = 40 - INT(LEN(TITLE$)/2)
  22. 1060  REM Draw the title box
  23. 1070  R1=3:C1=TITLE.POS-2:R2=6:C2=TITLE.POS+LEN(TITLE$)+1:GOSUB 1500
  24. 1080  REM Print the title
  25. 1090  LOCATE 4,TITLE.POS : PRINT TITLE$
  26. 1100  LOCATE 5,40-INT(LEN(VERSION$)/2) :  PRINT VERSION$;
  27. 1230  REM Draw the Copyright box
  28. 1240  R1 = 19 : C1 = 21 : R2 = 22 : C2 = 59 : GOSUB 1300
  29. 1250  REM Print the Copyright
  30. 1260  LOCATE 20,40-INT(LEN(COPY1$)/2) :  PRINT COPY1$;
  31. 1270  LOCATE 21,40-INT(LEN(COPY2$)/2) :  PRINT COPY2$;
  32. 1280  GOTO 1700
  33. 1300  REM subroutine to print a double box
  34. 1310  COLOR P
  35. 1320  FOR I = R1 + 1 TO R2 - 1
  36. 1330   LOCATE I, C1 : PRINT CHR$(186);
  37. 1340   LOCATE I, C2 : PRINT CHR$(186);
  38. 1350  NEXT I
  39. 1360   LOCATE R1, C1+1 : PRINT STRING$(C2-C1-1,205);
  40. 1390   LOCATE R2, C1+1 : PRINT STRING$(C2-C1-1,205);
  41. 1400   LOCATE R1, C1 : PRINT CHR$(201);
  42. 1410   LOCATE R1, C2 : PRINT CHR$(187);
  43. 1420   LOCATE R2, C1 : PRINT CHR$(200);
  44. 1430   LOCATE R2, C2 : PRINT CHR$(188);
  45. 1440  COLOR W
  46. 1450  RETURN
  47. 1500  REM subroutine to print a single box
  48. 1510  COLOR B
  49. 1520  FOR I = R1 + 1 TO R2 - 1
  50. 1530   LOCATE I, C1 : PRINT CHR$(179);
  51. 1540   LOCATE I, C2 : PRINT CHR$(179);
  52. 1550  NEXT I
  53. 1560   LOCATE R1, C1+1 : PRINT STRING$(C2-C1-1,196);
  54. 1590   LOCATE R2, C1+1 : PRINT STRING$(C2-C1-1,196);
  55. 1600   LOCATE R1, C1 : PRINT CHR$(218);
  56. 1610   LOCATE R1, C2 : PRINT CHR$(191);
  57. 1620   LOCATE R2, C1 : PRINT CHR$(192);
  58. 1630   LOCATE R2, C2 : PRINT CHR$(217);
  59. 1640  COLOR W
  60. 1650  RETURN
  61. 1700  REM ask user to press a key to continue
  62. 1710  LOCATE 25,1
  63. 1720  PRINT "Have Data Diskette(s) in Place, then Press any key to continue.";
  64. 1730  K$ = INKEY$ : IF K$ = "" THEN 1730
  65. 1740  KEY ON : CLS : KEY OFF
  66. 2000  REM LISTPCI Program Starts Here.
  67. 2010  OPEN DD.PERS$+"persfile" AS #1 LEN = 256
  68. 2020  FIELD 1, 5 AS F1$, 20 AS F2$, 30 AS F3$, 2 AS F4$, 5 AS F5$, 5 AS F6$, 5 AS F7$, 11 AS F8$, 18 AS F9$, 16 AS F10$, 16 AS F11$, 11 AS F12$, 18 AS F13$, 16 AS F14$, 16 AS F15$, 11 AS F16$, 18 AS F17$, 16 AS F18$, 16 AS F19$
  69. 2030  REM Read all records, and print the actual ones
  70. 2040  OPEN DD.PCIDX$+"pcindex" FOR INPUT AS #2
  71. 2050  INPUT #2, C
  72. 2060  KEY ON : CLS : KEY OFF : LOCATE 19,1
  73. 2070  PRINT "There are";C;"Parent/Child Index Records in the File"
  74. 2080  GOSUB 2100
  75. 2090  GOTO 2170
  76. 2100  LPRINT "Listing of the Parent/Child Index Records ";DATE$;"  ";TIME$
  77. 2110  LPRINT
  78. 2120  LPRINT "PARENT PARENT-NAME";
  79. 2130  LPRINT TAB(40);"CHILD  CHILD-NAME"
  80. 2140  LPRINT "------ -----------";
  81. 2150  LPRINT TAB(40);"-----  ----------"
  82. 2160  RETURN
  83. 2170  FOR I = 1 TO C
  84. 2180   INPUT #2, PAR.ID
  85. 2190   LOCATE 23,1 : PRINT "Listing Parent/Child Index Record";I
  86. 2200   LPRINT USING "####"; PAR.ID;
  87. 2210   GET #1, PAR.ID
  88. 2220   REM Extract information from the file for use
  89. 2230   T2$ = F2$
  90. 2240   T3$ = F3$
  91. 2250   FOR J = 1 TO LEN(F2$)-1
  92. 2260    IF RIGHT$(T2$,1)=" "THEN T2$ = LEFT$(T2$,LEN(T2$)-1) ELSE J = LEN(F2$)-1
  93. 2270   NEXT J
  94. 2280   FOR J = 1 TO LEN(F3$)-1
  95. 2290    IF RIGHT$(T3$,1)=" "THEN T3$ = LEFT$(T3$,LEN(T3$)-1) ELSE J = LEN(F3$)-1
  96. 2300   NEXT J
  97. 2310   LPRINT TAB(7); LEFT$(T2$+", "+T3$,32);
  98. 2320   INPUT #2, CHI.ID
  99. 2330   LPRINT TAB(40);: LPRINT USING "####"; CHI.ID;
  100. 2340   GET #1, CHI.ID
  101. 2350   T2$ = F2$
  102. 2360   T3$ = F3$
  103. 2370   FOR J = 1 TO LEN(F2$)-1
  104. 2380    IF RIGHT$(T2$,1)=" "THEN T2$ = LEFT$(T2$,LEN(T2$)-1) ELSE J = LEN(F2$)-1
  105. 2390   NEXT J
  106. 2400   FOR J = 1 TO LEN(F3$)-1
  107. 2410    IF RIGHT$(T3$,1)=" "THEN T3$ = LEFT$(T3$,LEN(T3$)-1) ELSE J = LEN(F3$)-1
  108. 2420   NEXT J
  109. 2430   LPRINT TAB(47); LEFT$(T2$+", "+T3$,32)
  110. 2440   IF I MOD 55 = 0 THEN LPRINT FORM.FEED$;: GOSUB 2100
  111. 2450  NEXT I
  112. 2460  CLOSE #2
  113. 2470  CLOSE #1
  114. 2480  KEY ON : CLS : KEY OFF : LOCATE 21,1
  115. 2490  PRINT "End of Program"
  116. 2500  LPRINT FORM.FEED$;
  117. 2510  RUN DD.MENU$+"menu"
  118.